

# WEST Search History

DATE: Sunday, December 07, 2003

| <u>Set Name</u>                      | <u>Query</u>                                                                                                                                                | <u>Hit Count</u> | <u>Set Name</u> |
|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-----------------|
| side by side                         |                                                                                                                                                             | result set       |                 |
| <i>DB=USPT,PGPB; PLUR=NO; OP=ADJ</i> |                                                                                                                                                             |                  |                 |
| L20                                  | pack\$3 with L19                                                                                                                                            | 2                | L20             |
| L19                                  | byte\$1 with L18                                                                                                                                            | 47               | L19             |
| L18                                  | store with interleav\$3                                                                                                                                     | 771              | L18             |
| L17                                  | byte\$1 with L16                                                                                                                                            | 18               | L17             |
| L16                                  | load with interleav\$3                                                                                                                                      | 479              | L16             |
| L15                                  | 6058408.pn.                                                                                                                                                 | 1                | L15             |
| L14                                  | interleav\$3 and L13                                                                                                                                        | 36               | L14             |
| L13                                  | L11 or L12<br>(4992934  5269007  5367705  5574928  5721892  5734874  5752271                                                                                | 292              | L13             |
| L12                                  | 5768609  5778241  5812147  5852726  5864713  5896543  5913054 <br>5918252  5983256)![uref]                                                                  | 278              | L12             |
| L11                                  | (4992934  5269007  5367705  5574928  5721892  5734874  5752271 <br>5768609  5778241  5812147  5852726  5864713  5896543  5913054 <br>5918252  5983256)![pn] | 16               | L11             |
| <i>DB=EPAB; PLUR=NO; OP=ADJ</i>      |                                                                                                                                                             |                  |                 |
| L10                                  | load and L9                                                                                                                                                 | 3                | L10             |
| L9                                   | fleck.in. and siemens.as.                                                                                                                                   | 27               | L9              |
| <i>DB=USPT; PLUR=NO; OP=ADJ</i>      |                                                                                                                                                             |                  |                 |
| L8                                   | fleck.in. and load and packed                                                                                                                               | 3                | L8              |
| <i>DB=DWPI; PLUR=NO; OP=ADJ</i>      |                                                                                                                                                             |                  |                 |
| L7                                   | fleck.in. and load and packed                                                                                                                               | 0                | L7              |
| <i>DB=EPAB; PLUR=NO; OP=ADJ</i>      |                                                                                                                                                             |                  |                 |
| L6                                   | fleck.in. and load and packed                                                                                                                               | 0                | L6              |
| L5                                   | fleck.in. and martin.in.                                                                                                                                    | 2                | L5              |
| <i>DB=DWPI; PLUR=NO; OP=ADJ</i>      |                                                                                                                                                             |                  |                 |
| L4                                   | fleck.in. and martin.in.                                                                                                                                    | 1                | L4              |
| <i>DB=USPT,PGPB; PLUR=NO; OP=ADJ</i> |                                                                                                                                                             |                  |                 |
| L3                                   | (5909572).pn.                                                                                                                                               | 1                | L3              |
| L2                                   | intel.asn. and (pack\$2 with unpack\$2) and interleav\$3                                                                                                    | 33               | L2              |
| L1                                   | intel                                                                                                                                                       | 39160            | L1              |

END OF SEARCH HISTORY

## WEST

  

L2: Entry 1 of 33

File: USPT

Feb 4, 2003

US-PAT-NO: 6516406

DOCUMENT-IDENTIFIER: US 6516406 B1

TITLE: Processor executing unpack instruction to interleave data elements from two packed data

DATE-ISSUED: February 4, 2003

## INVENTOR-INFORMATION:

| NAME                 | CITY          | STATE | ZIP CODE | COUNTRY |
|----------------------|---------------|-------|----------|---------|
| Peleg; Alexander     | Carmelia      |       |          | IL      |
| Yaari; Yaakov        | Hanadin       |       |          | IL      |
| Mittal; Millind      | Haifa         |       |          | IL      |
| Mennemeier; Larry M. | Boulder Creek | CA    |          |         |
| Eitan; Benny         | Haifa         |       |          | IL      |

## ASSIGNEE-INFORMATION:

| NAME              | CITY        | STATE | ZIP CODE | COUNTRY | TYPE CODE |
|-------------------|-------------|-------|----------|---------|-----------|
| Intel Corporation | Santa Clara | CA    |          |         | 02        |

APPL-NO: 09/ 657448 [PALM]

DATE FILED: September 8, 2000

## PARENT-CASE:

RELATED APPLICATIONS Continuation of application Ser. No. 08/974,435, filed Nov. 20, 1997, now Pat. No. 6,119,216, which is a Divisional of Ser. No. 08/791,003, filed Jan. 27, 1997, now Pat. No. 5,802,336, which is a Continuation of Ser. No. 08/349,047, filed Dec. 2, 1994, abandoned.

INT-CL: [07] G06 F 9/315

US-CL-ISSUED: 712/225, 712/22, 712/223, 712/300

US-CL-CURRENT: 712/225, 712/22, 712/223, 712/300

FIELD-OF-SEARCH: 712/223, 712/225, 712/300, 712/22

## PRIOR-ART-DISCLOSED:

## U.S. PATENT DOCUMENTS

| PAT-NO                                  | ISSUE-DATE     | PATENTEE-NAME      | US-CL   |
|-----------------------------------------|----------------|--------------------|---------|
| <input type="checkbox"/> <u>3711692</u> | January 1973   | Batcher            | 708/210 |
| <input type="checkbox"/> <u>3723715</u> | March 1973     | Chen et al.        | 708/709 |
| <input type="checkbox"/> <u>4139899</u> | February 1979  | Tulpule et al.     | 712/224 |
| <input type="checkbox"/> <u>4161784</u> | July 1979      | Cushing et al.     | 708/513 |
| <input type="checkbox"/> <u>4393468</u> | July 1983      | New                | 708/518 |
| <input type="checkbox"/> <u>4418383</u> | November 1983  | Doyle et al.       | 710/307 |
| <input type="checkbox"/> <u>4498177</u> | February 1985  | Larson             | 714/806 |
| <input type="checkbox"/> <u>4707800</u> | November 1987  | Montrone et al.    | 708/714 |
| <input type="checkbox"/> <u>4771379</u> | September 1988 | Ando et al.        | 712/42  |
| <input type="checkbox"/> <u>4903228</u> | February 1990  | Gregoire et al.    | 712/224 |
| <input type="checkbox"/> <u>4989168</u> | January 1991   | Kuroda et al.      | 708/210 |
| <input type="checkbox"/> <u>5081698</u> | January 1992   | Kohn               | 345/422 |
| <input type="checkbox"/> <u>5095457</u> | March 1992     | Jeong              | 708/626 |
| <input type="checkbox"/> <u>5168571</u> | December 1992  | Hoover et al.      | 712/210 |
| <input type="checkbox"/> <u>5187679</u> | February 1993  | Vassiliadis et al. | 708/706 |
| <input type="checkbox"/> <u>5268995</u> | December 1993  | Diefendorff et al. | 705/38  |
| <input type="checkbox"/> <u>5390135</u> | February 1995  | Lee et al.         | 708/518 |
| <input type="checkbox"/> <u>5408670</u> | April 1995     | Davies             | 712/16  |
| <input type="checkbox"/> <u>5423010</u> | June 1995      | Mizukami           | 341/60  |
| <input type="checkbox"/> <u>5426783</u> | June 1995      | Norrie et al.      | 712/225 |
| <input type="checkbox"/> <u>5465374</u> | November 1995  | Dinkjian et al.    | 711/219 |
| <input type="checkbox"/> <u>5487159</u> | January 1996   | Byers et al.       | 712/223 |
| <input type="checkbox"/> <u>5594437</u> | January 1997   | O'Malley           | 341/67  |
| <input type="checkbox"/> <u>5625374</u> | April 1997     | Turkowski          | 345/639 |
| <input type="checkbox"/> <u>5680161</u> | October 1997   | Lehman et al.      | 345/531 |
| <input type="checkbox"/> <u>5781457</u> | July 1998      | Cohen et al.       | 708/231 |
| <input type="checkbox"/> <u>5909552</u> | June 1999      | Jensen et al.      | 709/234 |
| <input type="checkbox"/> <u>5938756</u> | August 1999    | Van Hook et al.    | 712/23  |

## FOREIGN PATENT DOCUMENTS

| FOREIGN-PAT-NO | PUBN-DATE    | COUNTRY | US-CL |
|----------------|--------------|---------|-------|
| 0395348        | October 1990 | EP      |       |

## OTHER PUBLICATIONS

Diefendorff, Keith, et al. "Organization of the Motorola 88110 Superscalar RISC Microprocessor", pp. 40-63, (12)Apr. 1992, No. 2, Los Alamitos CA IEEE Micro.

Kawakami, Y., et al., "A Single-Chip Digital Signal Processor for Voiceband Applications," IEEE, 1980 International Solid-State Circuits Conference, pp. 40-41.

UltraSPARC Multimedia Capabilities On-Chip Support for Real0-Time Video and Advanced Graphics; SPARC Technology Business, Sep. 1994, Sun Microsystems, Inc.

Case, B., "Philips Hopes to Displace DSPs with VLIW, TriMedia Processors Aimed at Future Multimedia Embedded Apps," Microprocessor Report, Dec. 1994, pp. 12-18.

Gwynnep, L., "New PA-RISC Processor Decodes MPEG Video, H's PA-7100LC Uses New Instructions to Eliminate Decoder Chip," Microprocessor Report, Jan. 1994, pp. 16-17.

TMS320c2X, User's Guide, Digital Signal Processing Products, Texas Instruments, 1993,

pp. 3-2-3-11; 3-28-3-34; 4-1-4-22; 4-41; 4-103; 4-119; 4-120; 4-122; 4-150; 4-151.  
i860 TM. Microprocessor Family Programmer's Reference Manual, Intel Corporation, 1992,  
Chapters 1, 3, 8 and 12.  
Lee, R.B., "Accelerating Multimedia with Enhanced Microprocessors," IEEE Micro, Apr.  
1995, pp. 22-32.  
Pentium Processor's User's Manual, vol. 3: Architecture and Programming Manual, Intel  
Corporation, 1993, Chapters 1, 3, 4, 6, 8, and 18.  
Margulis, N., "i860 Microprocessor Architecture," McGraw Hill, Inc., 1990, Chapters 6,  
7, 8, 10, and 11.  
Intel i750, i860 TM, i960 Processors and Related Products, 1993, pp. 1-3.  
Motorola MC88110 Second Generation RISC Microprocessor User's Manual, Motorola, Inc.,  
1991.  
MC88110 Second Generation-RISC Microprocessor User's Manual, Motorola, Inc., Sep.  
1992, pp. 2-1 through 2-22, 3-1 through 3-32, 5-1 through 5-25, 10-62 through 10-71,  
Index 1 through 17.  
Errata to MC88110 Second Generation RISC Microprocessor User's Manual, Motorola, Inc.,  
1992, pp. 1-11.  
MC88110 Programmer's Reference Guide, Motorola, Inc., 1992, pp. 1-4.  
Shipnes, J., "Graphics Processing with the 88110 RISC Microprocessor," Motorola, Inc.,  
IEEE, No. 0-8186-26455-0/92, 1992, pp. 169-174.

ART-UNIT: 2183

PRIMARY-EXAMINER: Kim; Kenneth S.

ATTY-AGENT-FIRM: Blakely, Sokoloff, Taylor & Zafman LLP

ABSTRACT:

An apparatus includes an instruction decoder, first and second source registers and a circuit coupled to the decoder to receive packed data from the source registers and to unpack the packed data responsive to an unpack instruction received by the decoder. A first packed data element and a third packed data element are received from the first source register. A second packed data element and a fourth packed data element are received from the second source register. The circuit copies the packed data elements into a destination register resulting with the second packed data element adjacent to the first packed data element, the third packed data element adjacent to the second packed data element, and the fourth packed data element adjacent to the third packed data element.

18 Claims, 18 Drawing figures

## WEST



Generate Collection

Print

L2: Entry 1 of 33

File: USPT

Feb 4, 2003

DOCUMENT-IDENTIFIER: US 6516406 B1

TITLE: Processor executing unpack instruction to interleave data elements from two packed dataAbstract Text (1):

An apparatus includes an instruction decoder, first and second source registers and a circuit coupled to the decoder to receive packed data from the source registers and to unpack the packed data responsive to an unpack instruction received by the decoder. A first packed data element and a third packed data element are received from the first source register. A second packed data element and a fourth packed data element are received from the second source register. The circuit copies the packed data elements into a destination register resulting with the second packed data element adjacent to the first packed data element, the third packed data element adjacent to the second packed data element, and the fourth packed data element adjacent to the third packed data element.

Assignee Name (1):Intel CorporationBrief Summary Text (3):

The present invention includes an apparatus and method of performing operations using a single control signal to manipulate multiple data elements. The present invention allows execution of move, pack and unpack operations on packed data types.

Brief Summary Text (11):

A processor. The processor includes a first register for storing a first packed data, a decoder, and a functional unit. The decoder has a control signal input. The control signal input is for receiving a first control signal and a second control signal. The first control signal is for indicating a pack operation. The second control signal is for indicating an unpack operation. The functional unit is coupled to the decoder and the register. The functional unit is for performing the pack operation and the unpack operation using the first packed data. The processor also supports a move operation.

Drawing Description Text (15):

FIG. 9 illustrates one embodiment of a method followed by a processor when performing an unpack operation on packed data.

Drawing Description Text (16):

FIG. 10 illustrates a circuit capable of implementing an unpack operation on packed data.

Detailed Description Text (3):

A processor having move, pack, and unpack operations that operate on multiple data elements is described. In the following description, numerous specific details are set forth such as circuits, etc., in order to provide a thorough understanding of the present invention. In other instances, well-known structures and techniques have not been shown in detail in order not to unnecessarily obscure the present invention.

Detailed Description Text (19):

FIG. 3 illustrates the general operation of processor 109. That is, FIG. 3 illustrates the steps followed by processor 109 while performing an operation on packed data, performing an operation on unpacked data, or performing some other operation. For example, such operations include a load operation to load a register in register file

204 with data from cache 206, main memory 104, read only memory (ROM) 106, or data storage device 107. In one embodiment of the present invention, processor 109 supports most of the instructions supported by the Intel 80486.TM., available from Intel Corporation of Santa Clara, Calif. In another embodiment of the present invention, processor 109 supports all the operations supported by the Intel 80486.TM., available from Intel Corporation of Santa Clara, Calif. In another embodiment of the present invention, processor 109 supports all the operations supported by the Pentium.TM. processor, the Intel 80486.TM. processor, the 80386.TM. processor, the Intel 80286.TM. processor, and the Intel 8086.TM. processor, all available from Intel Corporation of Santa Clara, Calif. In another embodiment of the present invention, processor 109 supports all the operations supported in the IA.TM.--Intel Architecture, as defined by Intel Corporation of Santa Clara, Calif. (see Microprocessors. Intel Data Books volume 1 and volume 2, 1992 and 1993, available from Intel of Santa Clara, Calif.). Generally, processor 109 can support the present instruction set for the Pentium.TM. processor, but can also be modified to incorporate future instructions, as well as those described herein. What is important is that general processor 109 can support previously used operations in addition to the operations described herein.

Detailed Description Text (51):

In one embodiment of the present invention, the performance of multimedia applications is improved by not only supporting a standard CISC instruction set (unpacked data operations), but by supporting operations on packed data. Such packed data operations can include an addition, a subtraction, a multiplication, a compare, a shift, an AND, and an XOR. However, to take full advantage of these operations, it has been determined that data manipulation operations should be included. Such data manipulation operations can include a move, a pack, and an unpack. Move, pack and unpack facilitate the execution of the other operations by generating packed data in formats that allow for easier use by programmers.

Detailed Description Text (83):

In one embodiment, an unpack operation interleaves the low order packed bytes, words or doublewords of two source packed data to generate result packed bytes, words, or doublewords.

Detailed Description Text (84):

FIG. 9 illustrates one embodiment of a method of performing an unpack operation on packed data. This embodiment can be implemented in the processor 109 of FIG. 2.

Detailed Description Text (96):

In one embodiment of the present invention, to achieve efficient execution of the unpack operation parallelism is used. FIG. 10 illustrates one embodiment of a circuit that can perform an unpack operation on packed data.

Detailed Description Text (104):

Therefore, the move, pack and unpack operations can manipulate multiple data elements. In prior art processors, to perform these types of manipulations, multiple separate operations would be needed to perform a single packed move, pack or unpack operation. The data lines for the packed data operations, in one embodiment, all carry relevant data. This leads to a higher performance computer system.

**CLAIMS:**

1. An apparatus comprising: a instruction decoder to receive an unpack instruction; a first source register to hold a first packed data having a first plurality of packed data elements including a first packed data element and a third packed data element; a second source register to hold a second packed data having a second plurality of packed data elements including a second packed data element and a fourth packed data element; a destination register to hold a third packed data; a circuit coupled to the decoder to receive the first packed data from the first source register and the second packed data from the second source register and to unpack the first packed data and the second packed data responsive to the unpack instruction by copying the first packed data element into the destination register, copying the second packed data element into the destination register adjacent to the first packed data element, copying the third packed data element into the destination register adjacent to the second packed data element, and copying the fourth packed data element into the

destination register adjacent to the third packed data element.

7. The apparatus of claim 2 wherein the decoder further decodes the unpack instruction, a first byte and a second byte of the three bytes comprising an operation code specifying an unpack operation to interleave low order packed elements from the first and second packed data, the elements selected from the group consisting of byte elements, word elements and doubleword elements.

12. The apparatus of claim 1 wherein the first packed data element is a low order data element of the first packed data and the second packed data element is a low order data element of the second packed data and the unpack instruction comprises an opcode field to contain one of a set of operation codes to specify an unpack operation interleaving low order data elements from the first and the second pluralities of packed data elements, the opcode field specifying data elements selected from the group consisting of byte elements, word elements and doubleword elements.

14. The apparatus of claim 1 wherein the first packed data element is a high order data element of the first packed data and the second packed data element is a high order data element of the second packed data and the unpack instruction comprises an opcode field to contain one of a set of operation codes to specify an unpack operation interleaving high order data elements from the first and the second pluralities of packed data elements, the opcode field specifying data elements selected from the group consisting of byte elements, word elements and doubleword elements.

16. A digital processing apparatus comprising: a decoder to receive an unpack control signal having an Intel integer opcode format comprising three or more bytes, a third byte of the three or more bytes permitting a first three-bit source register address and a second three-bit source-destination register address; a first register to hold a first packed data having a first plurality of packed data elements including a first packed data element and a third packed data element, the first register corresponding to the first three-bit source register address; a second register to hold a second packed data having a second plurality of packed data elements including a second packed data element and a fourth packed data element, the second register corresponding to the second three-bit source-destination register address; a circuit to receive the first packed data from the first register and the second packed data from the second register, and in response to the unpack control signal, to copy the first packed data element into the second register, copy the second packed data element into the second register adjacent to the first packed data element, copy the third packed data element into the second register adjacent to the second packed data element, and copy the fourth packed data element into the second register adjacent to the third packed data element.

17. The digital processing apparatus recited in claim 16 wherein the decoder is further to receive the unpack control signal having an Intel integer opcode format as described in the "Pentium.RTM. Processor Family User's Manual," the Intel integer opcode format comprising three or more bytes, a first byte and a second byte of the three or more bytes permitting an operation code to specify an unpack operation interleaving low order packed byte elements, word elements or doubleword elements from the first and second packed data;

18. A computer system comprising: a memory to hold an unpack instruction having an Intel integer opcode format comprising three or more bytes, one of the three or more bytes permitting a first three-bit source register address and a second three-bit source-destination register address; a storage device to hold software, the software configured to supply the unpack instruction to the memory for execution; a processor enabled to receive and decode the unpack instruction from the memory, the processor including: a first register corresponding to the first three-bit source register address to hold a first packed data having a first plurality of packed data elements including a first packed data element and a third packed data element, a second register corresponding to the second three-bit source-destination register address to hold a second packed data having a second plurality of packed data elements including a second packed data element and a fourth packed data element, and a circuit to receive the first packed data from the first register and the second packed data from the second register and to copy the first packed data element into the second register, copy the second packed data element into the second register adjacent to the first packed data element.

first packed data element, copy the third packed data element into the second register adjacent to the second packed data element, and copy the fourth packed data element into the second register adjacent to the third packed data element.

## WEST

 Generate Collection 

L2: Entry 13 of 33

File: USPT

Sep 12, 2000

DOCUMENT-IDENTIFIER: US 6119216 A

\*\* See image for Certificate of Correction \*\*

TITLE: Microprocessor capable of unpacking packed data in response to a unpack instructionAbstract Text (1):

A microprocessor capable of unpacking packed data in response to an unpack instruction. The microprocessor having a storage area to store a first packed data and a second packed data respectively including a first plurality of data elements and a second plurality of data elements, wherein each data element in the first plurality of data elements corresponds to a different data element in the second plurality of data elements, in a respective position. The microprocessor also includes a circuit that simultaneously copies less than all data elements from the first plurality of data elements and corresponding data elements from the second plurality of data elements into a storage area as a third plurality of separate data elements in a third packed data in response to the unpack instruction.

Assignee Name (1):

Intel Corporation

Brief Summary Text (3):

The present invention includes an apparatus and method of performing operations using a single control signal to manipulate multiple data elements. The present invention allows execution of move, pack and unpack operations on packed data types.

Brief Summary Text (11):

A processor. The processor includes a first register for storing a first packed data, a decoder, and a functional unit. The decoder has a control signal input. The control signal input is for receiving a first control signal and a second control signal. The first control signal is for indicating a pack operation. The second control signal is for indicating an unpack operation. The functional unit is coupled to the decoder and the register. The functional unit is for performing the pack operation and the unpack operation using the first packed data. The processor also supports a move operation.

Drawing Description Text (15):

FIG. 9 illustrates an embodiment of a method followed by a processor when performing an unpack operation on packed data.

Drawing Description Text (16):

FIG. 10 illustrates a circuit capable of implementing an unpack operation on packed data.

Detailed Description Text (3):

A processor having move, pack, and unpack operations that operate on multiple data elements is described. In the following description, numerous specific details are set forth such as circuits, etc., in order

Detailed Description Text (20):

FIG. 3 illustrates the general operation of processor 109. That is, FIG. 3 illustrates the steps followed by processor 109 while performing an operation on packed data, performing an operation on unpacked data, or performing some other operation. For example, such operations include a load operation to load a register in register file 204 with data from cache 206, main memory 104, read only memory (ROM) 106, or data

storage device 107. In one embodiment of the present invention, processor 109 supports most of the instructions supported by the Intel 80486.TM., available from Intel Corporation of Santa Clara, Calif. In another embodiment of the present invention, processor 109 supports all the operations supported by the Intel 80486.TM., available from Intel Corporation of Santa Clara, Calif. In another embodiment of the present invention, processor 109 supports all the operations supported by the Pentium.TM. processor, the Intel 80486.TM. processor, the 80386.TM. processor, the Intel 80286.TM. processor, and the Intel 8086.TM. processor, all available from Intel Corporation of Santa Clara, Calif. In another embodiment of the present invention, processor 109 supports all the operations supported in the IA.TM.--Intel Architecture, as defined by Intel Corporation of Santa Clara, Calif. (see Microprocessors, Intel Data Books volume 1 and volume 2, 1992 and 1993, available from Intel of Santa Clara, Calif.). Generally, processor 109 can support the present instruction set for the Pentium198 processor, but can also be modified to incorporate future instructions, as well as those described herein. What is important is that general processor 109 can support previously used operations in addition to the operations described herein.

Detailed Description Text (53):

In one embodiment of the present invention, the performance of multimedia applications is improved by not only supporting a standard CISC instruction set (unpacked data operations), but by supporting operations on packed data. Such packed data operations can include an addition, a subtraction, a multiplication, a compare, a shift, an AND, and an XOR. However, to take full advantage of these operations, it has been determined that data manipulation operations should be included. Such data manipulation operations can include a move, a pack, and an unpack. Move, pack and unpack facilitate the execution of the other operations by generating packed data in formats that allow for easier use by programmers.

Detailed Description Text (86):

In one embodiment, an unpack operation interleaves the low order packed bytes, words or doublewords of two source packed data to generate result packed bytes, words, or doublewords.

Detailed Description Text (87):

FIG. 9 illustrates one embodiment of a method of performing an unpack operation on packed data. This embodiment can be implemented in the processor 109 of FIG. 2.

Detailed Description Text (100):

In one embodiment of the present invention, to achieve efficient execution of the unpack operation parallelism is used. FIG. 10 illustrates one embodiment of a circuit that can perform an unpack operation on packed data.

Detailed Description Text (108):

Therefore, the move pack and unpack operations can manipulate multiple data elements. In prior art processors, to perform these types of manipulations, multiple separate operations would be needed to perform a single packed move, pack or unpack operation. The data lines for the packed data operations, in one embodiment, all carry relevant data. This leads to a higher performance computer system.

## WEST

  

L2: Entry 13 of 33

File: USPT

Sep 12, 2000

US-PAT-NO: 6119216

DOCUMENT-IDENTIFIER: US 6119216 A

\*\* See image for Certificate of Correction \*\*

TITLE: Microprocessor capable of unpacking packed data in response to a unpack instruction

DATE-ISSUED: September 12, 2000

## INVENTOR-INFORMATION:

| NAME                 | CITY          | STATE | ZIP CODE | COUNTRY |
|----------------------|---------------|-------|----------|---------|
| Peleg; Alexander     | Carmelia      |       |          | IL      |
| Yaari; Yaakov        | Haifa         |       |          | IL      |
| Mittal; Millind      | Haifa         |       |          | IL      |
| Mennemeier; Larry M. | Boulder Creek | CA    |          |         |
| Eitan; Benny         | Haifa         |       |          | IL      |

## ASSIGNEE-INFORMATION:

| NAME                     | CITY        | STATE | ZIP CODE | COUNTRY | TYPE CODE |
|--------------------------|-------------|-------|----------|---------|-----------|
| <u>Intel</u> Corporation | Santa Clara | CA    |          |         | 02        |

APPL-NO: 08/ 974435 [PALM]

DATE FILED: March 22, 1999

## PARENT-CASE:

This application is a division of application Ser. No. 08/791,003, filed Jan. 27, 1997, now issued U.S. Pat. No. 5,802,336, which is a continuation of application Ser. No. 08/349,047, filed Dec. 2, 1994, now abandoned.

INT-CL: [07] G06 F 9/30

US-CL-ISSUED: 712/22; 712/221, 712/223, 712/225

US-CL-CURRENT: 712/22; 712/221, 712/223, 712/225

FIELD-OF-SEARCH: 712/221, 712/223, 712/225, 712/22

## PRIOR-ART-DISCLOSED:

## U.S. PATENT DOCUMENTS

| PAT-NO                                  | ISSUE-DATE    | PATENTEE-NAME     | US-CL   |
|-----------------------------------------|---------------|-------------------|---------|
| <input type="checkbox"/> <u>5423010</u> | June 1995     | Mizukami          | 341/60  |
| <input type="checkbox"/> <u>5625374</u> | April 1997    | Turkowski         | 345/113 |
| <input type="checkbox"/> <u>5680161</u> | October 1997  | Lehman et al.     | 345/515 |
| <input type="checkbox"/> <u>5835782</u> | November 1998 | Lin et al.        | 712/42  |
| <input type="checkbox"/> <u>5862067</u> | January 1999  | Mennemeien et al. | 708/501 |

ART-UNIT: 273

PRIMARY-EXAMINER: Kim, Kenneth S.

ATTY-AGENT-FIRM: Blakely, Sokoloff, Taylor & Zafman LLP

ABSTRACT:

A microprocessor capable of unpacking packed data in response to an unpack instruction. The microprocessor having a storage area to store a first packed data and a second packed data respectively including a first plurality of data elements and a second plurality of data elements, wherein each data element in the first plurality of data elements corresponds to a different data element in the second plurality of data elements, in a respective position. The microprocessor also includes a circuit that simultaneously copies less than all data elements from the first plurality of data elements and corresponding data elements from the second plurality of data elements into a storage area as a third plurality of separate data elements in a third packed data in response to the unpack instruction.

17 Claims, 18 Drawing figures